package cn.cordys.crm.integration.sqlbot.handler.field;


import cn.cordys.crm.integration.sqlbot.handler.field.api.TextFieldParser;
import cn.cordys.crm.system.constants.FieldSourceType;
import cn.cordys.crm.system.dto.field.DatasourceMultipleField;
import org.apache.commons.lang3.Strings;

import java.text.MessageFormat;

public class DatasourceMultipleParser extends TextFieldParser<DatasourceMultipleField> {

    public static final String MEMBER_OPTION_FIELD_SQL_TEMPLATE = """
            (
               SELECT JSON_ARRAYAGG(ds.name)
               FROM {0} f
               join {1} ds on f.field_value like concat(''%'', ds.id, ''%'')
               WHERE f.resource_id = c.id AND f.field_id = ''{2}''
               LIMIT 1
            ) AS ''{3}''
            """;

    @Override
    public String parseSql(String fieldValueTable, DatasourceMultipleField field) {
        String datasourceTableName = field.getDataSourceType().toLowerCase();
        if (Strings.CI.equals(datasourceTableName, FieldSourceType.CONTACT.name())) {
            datasourceTableName = "customer_contact";
        }
        return MessageFormat.format(MEMBER_OPTION_FIELD_SQL_TEMPLATE,
                fieldValueTable + "_blob",
                datasourceTableName,
                field.getId(),
                field.getId()
        );
    }
}
